html,
body {
    height: 100%;
    background-color: #f4f5f6;
}
#wrap{
    height: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-flex-flow: column;
           flex-flow: column;
}
#header{
    text-align: center;
    background-color: #5571be;
    border-bottom: 1px solid #ccc;
    width: 100%;
    height: 40px;
    /*box-sizing: border-box;*/
    position: relative;

    /*margin-top: 30px;*/
}
#header h1{
    font-size: 20px; height: 40px; line-height: 40px; margin: 0em; color: #fff;
}
#main{
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    flex: 1;
    /*background: yellow;*/
}
.login_box {
    box-sizing: border-box;
    padding: 30px 20px;
}

.phone {
    width: 100%;
    height: 43px;
    line-height: 43px;
    border: 1px solid #e8e8e8;
    background-color: #fff;
}

.phone input,
.password input {
    width: 100%;
    height: 43px;
    line-height: 16px;
    outline: none;
    font-size: 14px;
    color: #999;
    box-sizing: border-box;
    padding-left: 10px;
}

.password {
    width: 100%;
    height: 43px;
    border: 1px solid #e8e8e8;
    border-top: none;
    background-color: #fff;
    position: relative;
}


.login {
    width: 100%;
    height: 44px;
    line-height: 44px;
    text-align: center;
    font-size: 13px;
    color: #fff;
    border-radius: 4px;
    background-color: #5571be;
    margin: 20px 0 10px;
    outline: none;
}
.flex-con{
  overflow: auto
}
